app(app(add, 0), y) → y
app(app(add, app(s, x)), y) → app(s, app(app(add, x), y))
app(app(mult, 0), y) → 0
app(app(mult, app(s, x)), y) → app(app(add, app(app(mult, x), y)), y)
app(app(app(rec, f), x), 0) → x
app(app(app(rec, f), x), app(s, y)) → app(app(f, app(s, y)), app(app(app(rec, f), x), y))
fact → app(app(rec, mult), app(s, 0))
↳ QTRS
↳ Overlay + Local Confluence
app(app(add, 0), y) → y
app(app(add, app(s, x)), y) → app(s, app(app(add, x), y))
app(app(mult, 0), y) → 0
app(app(mult, app(s, x)), y) → app(app(add, app(app(mult, x), y)), y)
app(app(app(rec, f), x), 0) → x
app(app(app(rec, f), x), app(s, y)) → app(app(f, app(s, y)), app(app(app(rec, f), x), y))
fact → app(app(rec, mult), app(s, 0))
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
app(app(add, 0), y) → y
app(app(add, app(s, x)), y) → app(s, app(app(add, x), y))
app(app(mult, 0), y) → 0
app(app(mult, app(s, x)), y) → app(app(add, app(app(mult, x), y)), y)
app(app(app(rec, f), x), 0) → x
app(app(app(rec, f), x), app(s, y)) → app(app(f, app(s, y)), app(app(app(rec, f), x), y))
fact → app(app(rec, mult), app(s, 0))
app(app(add, 0), x0)
app(app(add, app(s, x0)), x1)
app(app(mult, 0), x0)
app(app(mult, app(s, x0)), x1)
app(app(app(rec, x0), x1), 0)
app(app(app(rec, x0), x1), app(s, x2))
fact
APP(app(add, app(s, x)), y) → APP(app(add, x), y)
APP(app(app(rec, f), x), app(s, y)) → APP(f, app(s, y))
APP(app(mult, app(s, x)), y) → APP(add, app(app(mult, x), y))
APP(app(mult, app(s, x)), y) → APP(app(add, app(app(mult, x), y)), y)
APP(app(add, app(s, x)), y) → APP(s, app(app(add, x), y))
APP(app(add, app(s, x)), y) → APP(add, x)
FACT → APP(s, 0)
FACT → APP(rec, mult)
APP(app(mult, app(s, x)), y) → APP(app(mult, x), y)
APP(app(app(rec, f), x), app(s, y)) → APP(app(f, app(s, y)), app(app(app(rec, f), x), y))
FACT → APP(app(rec, mult), app(s, 0))
APP(app(mult, app(s, x)), y) → APP(mult, x)
APP(app(app(rec, f), x), app(s, y)) → APP(app(app(rec, f), x), y)
app(app(add, 0), y) → y
app(app(add, app(s, x)), y) → app(s, app(app(add, x), y))
app(app(mult, 0), y) → 0
app(app(mult, app(s, x)), y) → app(app(add, app(app(mult, x), y)), y)
app(app(app(rec, f), x), 0) → x
app(app(app(rec, f), x), app(s, y)) → app(app(f, app(s, y)), app(app(app(rec, f), x), y))
fact → app(app(rec, mult), app(s, 0))
app(app(add, 0), x0)
app(app(add, app(s, x0)), x1)
app(app(mult, 0), x0)
app(app(mult, app(s, x0)), x1)
app(app(app(rec, x0), x1), 0)
app(app(app(rec, x0), x1), app(s, x2))
fact
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ EdgeDeletionProof
APP(app(add, app(s, x)), y) → APP(app(add, x), y)
APP(app(app(rec, f), x), app(s, y)) → APP(f, app(s, y))
APP(app(mult, app(s, x)), y) → APP(add, app(app(mult, x), y))
APP(app(mult, app(s, x)), y) → APP(app(add, app(app(mult, x), y)), y)
APP(app(add, app(s, x)), y) → APP(s, app(app(add, x), y))
APP(app(add, app(s, x)), y) → APP(add, x)
FACT → APP(s, 0)
FACT → APP(rec, mult)
APP(app(mult, app(s, x)), y) → APP(app(mult, x), y)
APP(app(app(rec, f), x), app(s, y)) → APP(app(f, app(s, y)), app(app(app(rec, f), x), y))
FACT → APP(app(rec, mult), app(s, 0))
APP(app(mult, app(s, x)), y) → APP(mult, x)
APP(app(app(rec, f), x), app(s, y)) → APP(app(app(rec, f), x), y)
app(app(add, 0), y) → y
app(app(add, app(s, x)), y) → app(s, app(app(add, x), y))
app(app(mult, 0), y) → 0
app(app(mult, app(s, x)), y) → app(app(add, app(app(mult, x), y)), y)
app(app(app(rec, f), x), 0) → x
app(app(app(rec, f), x), app(s, y)) → app(app(f, app(s, y)), app(app(app(rec, f), x), y))
fact → app(app(rec, mult), app(s, 0))
app(app(add, 0), x0)
app(app(add, app(s, x0)), x1)
app(app(mult, 0), x0)
app(app(mult, app(s, x0)), x1)
app(app(app(rec, x0), x1), 0)
app(app(app(rec, x0), x1), app(s, x2))
fact
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ EdgeDeletionProof
↳ QDP
↳ DependencyGraphProof
APP(app(add, app(s, x)), y) → APP(app(add, x), y)
APP(app(app(rec, f), x), app(s, y)) → APP(f, app(s, y))
APP(app(mult, app(s, x)), y) → APP(add, app(app(mult, x), y))
APP(app(mult, app(s, x)), y) → APP(app(add, app(app(mult, x), y)), y)
APP(app(add, app(s, x)), y) → APP(s, app(app(add, x), y))
APP(app(add, app(s, x)), y) → APP(add, x)
FACT → APP(s, 0)
FACT → APP(rec, mult)
FACT → APP(app(rec, mult), app(s, 0))
APP(app(app(rec, f), x), app(s, y)) → APP(app(f, app(s, y)), app(app(app(rec, f), x), y))
APP(app(mult, app(s, x)), y) → APP(app(mult, x), y)
APP(app(mult, app(s, x)), y) → APP(mult, x)
APP(app(app(rec, f), x), app(s, y)) → APP(app(app(rec, f), x), y)
app(app(add, 0), y) → y
app(app(add, app(s, x)), y) → app(s, app(app(add, x), y))
app(app(mult, 0), y) → 0
app(app(mult, app(s, x)), y) → app(app(add, app(app(mult, x), y)), y)
app(app(app(rec, f), x), 0) → x
app(app(app(rec, f), x), app(s, y)) → app(app(f, app(s, y)), app(app(app(rec, f), x), y))
fact → app(app(rec, mult), app(s, 0))
app(app(add, 0), x0)
app(app(add, app(s, x0)), x1)
app(app(mult, 0), x0)
app(app(mult, app(s, x0)), x1)
app(app(app(rec, x0), x1), 0)
app(app(app(rec, x0), x1), app(s, x2))
fact
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ EdgeDeletionProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ QDP
APP(app(add, app(s, x)), y) → APP(app(add, x), y)
app(app(add, 0), y) → y
app(app(add, app(s, x)), y) → app(s, app(app(add, x), y))
app(app(mult, 0), y) → 0
app(app(mult, app(s, x)), y) → app(app(add, app(app(mult, x), y)), y)
app(app(app(rec, f), x), 0) → x
app(app(app(rec, f), x), app(s, y)) → app(app(f, app(s, y)), app(app(app(rec, f), x), y))
fact → app(app(rec, mult), app(s, 0))
app(app(add, 0), x0)
app(app(add, app(s, x0)), x1)
app(app(mult, 0), x0)
app(app(mult, app(s, x0)), x1)
app(app(app(rec, x0), x1), 0)
app(app(app(rec, x0), x1), app(s, x2))
fact
ADD(s(x), y) → ADD(x, y)
add(0, x0)
add(s(x0), x1)
mult(0, x0)
mult(s(x0), x1)
rec(x0, x1, 0)
rec(x0, x1, s(x2))
fact
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
APP(app(add, app(s, x)), y) → APP(app(add, x), y)
s1 > ADD1
s1: multiset
ADD1: multiset
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ EdgeDeletionProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ PisEmptyProof
↳ QDP
↳ QDP
app(app(add, 0), y) → y
app(app(add, app(s, x)), y) → app(s, app(app(add, x), y))
app(app(mult, 0), y) → 0
app(app(mult, app(s, x)), y) → app(app(add, app(app(mult, x), y)), y)
app(app(app(rec, f), x), 0) → x
app(app(app(rec, f), x), app(s, y)) → app(app(f, app(s, y)), app(app(app(rec, f), x), y))
fact → app(app(rec, mult), app(s, 0))
app(app(add, 0), x0)
app(app(add, app(s, x0)), x1)
app(app(mult, 0), x0)
app(app(mult, app(s, x0)), x1)
app(app(app(rec, x0), x1), 0)
app(app(app(rec, x0), x1), app(s, x2))
fact
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ EdgeDeletionProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDPOrderProof
↳ QDP
APP(app(mult, app(s, x)), y) → APP(app(mult, x), y)
app(app(add, 0), y) → y
app(app(add, app(s, x)), y) → app(s, app(app(add, x), y))
app(app(mult, 0), y) → 0
app(app(mult, app(s, x)), y) → app(app(add, app(app(mult, x), y)), y)
app(app(app(rec, f), x), 0) → x
app(app(app(rec, f), x), app(s, y)) → app(app(f, app(s, y)), app(app(app(rec, f), x), y))
fact → app(app(rec, mult), app(s, 0))
app(app(add, 0), x0)
app(app(add, app(s, x0)), x1)
app(app(mult, 0), x0)
app(app(mult, app(s, x0)), x1)
app(app(app(rec, x0), x1), 0)
app(app(app(rec, x0), x1), app(s, x2))
fact
MULT(s(x), y) → MULT(x, y)
add(0, x0)
add(s(x0), x1)
mult(0, x0)
mult(s(x0), x1)
rec(x0, x1, 0)
rec(x0, x1, s(x2))
fact
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
APP(app(mult, app(s, x)), y) → APP(app(mult, x), y)
s1 > MULT1
MULT1: multiset
s1: multiset
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ EdgeDeletionProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ PisEmptyProof
↳ QDP
app(app(add, 0), y) → y
app(app(add, app(s, x)), y) → app(s, app(app(add, x), y))
app(app(mult, 0), y) → 0
app(app(mult, app(s, x)), y) → app(app(add, app(app(mult, x), y)), y)
app(app(app(rec, f), x), 0) → x
app(app(app(rec, f), x), app(s, y)) → app(app(f, app(s, y)), app(app(app(rec, f), x), y))
fact → app(app(rec, mult), app(s, 0))
app(app(add, 0), x0)
app(app(add, app(s, x0)), x1)
app(app(mult, 0), x0)
app(app(mult, app(s, x0)), x1)
app(app(app(rec, x0), x1), 0)
app(app(app(rec, x0), x1), app(s, x2))
fact
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ EdgeDeletionProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
APP(app(app(rec, f), x), app(s, y)) → APP(f, app(s, y))
APP(app(app(rec, f), x), app(s, y)) → APP(app(f, app(s, y)), app(app(app(rec, f), x), y))
APP(app(app(rec, f), x), app(s, y)) → APP(app(app(rec, f), x), y)
app(app(add, 0), y) → y
app(app(add, app(s, x)), y) → app(s, app(app(add, x), y))
app(app(mult, 0), y) → 0
app(app(mult, app(s, x)), y) → app(app(add, app(app(mult, x), y)), y)
app(app(app(rec, f), x), 0) → x
app(app(app(rec, f), x), app(s, y)) → app(app(f, app(s, y)), app(app(app(rec, f), x), y))
fact → app(app(rec, mult), app(s, 0))
app(app(add, 0), x0)
app(app(add, app(s, x0)), x1)
app(app(mult, 0), x0)
app(app(mult, app(s, x0)), x1)
app(app(app(rec, x0), x1), 0)
app(app(app(rec, x0), x1), app(s, x2))
fact